草庐IT

java - 将 UUID 存储为 base64 字符串

全部标签

ruby-on-rails - 回形针可以读取 S3 存储桶中的照片几何图形吗?

我想从我的S3容器中读取照片的几何形状。当它在我的本地时,这是有效的:defphoto_geometry(style=:original)@geometry||={}@geometry[style]||=Paperclip::Geometry.from_filephoto.path(style)end但是当我将模型切换到S3时它似乎不起作用。有什么建议吗?更大的故事是,我正在尝试编写一些代码,允许我从S3检索照片,允许用户裁剪它们,然后将它们重新上传回S3,仍然由回形针分配。编辑:这是返回的错误:Paperclip::NotIdentifiedByImageMagickError:ph

ruby - 在 ruby​​/ActiveRecord 中生成类似 Instagram 或 Youtube 的不可猜测的字符串 ID

在创建给定ActiveRecord模型对象的实例后,我需要生成一个简短的(6-8个字符)唯一字符串用作URL中的标识符,采用Instagram照片URL的样式(如http://instagram.com/p/P541i4ErdL/,它我只是争先恐后地成为404)或Youtube的视频网址(如http://www.youtube.com/watch?v=oHg5SJYRHA0)。执行此操作的最佳方法是什么?最简单的是createarandomstring重复直到它是唯一的?有没有一种方法可以对整数ID进行散列/洗牌,使用户无法通过更改一个字符来破解URL(就像我对上面的404'sInst

ruby - ruby 是否具有与 synchronize 关键字等效的 Java?

ruby是否有Java中的synchronize关键字?我使用的是1.9.1,但我不太明白执行此操作的优雅方式。 最佳答案 它没有synchronize关键字,但您可以通过Monitor类获得非常相似的东西。以下是ProgrammingRuby1.8一书中的示例:require'monitor'classCounter 关于ruby-ruby是否具有与synchronize关键字等效的Java?,我们在StackOverflow上找到一个类似的问题: http

ruby - Ruby 2.0 中的二进制字符串文字

当升级到Ruby2.0时,一个测试用例开始失败:expected="\xD1\x9B\x86"assert_equalexpected,actual带有以下消息:expectedbutwas.actual变量包含从外部库调用中获得的二进制字符串。问题是源文件的默认编码(以及字符串文字)changedinRuby2.0从US-ASCII到UTF-8。 最佳答案 解决方案是更改字符串文字的定义以强制执行其编码。有几个可能的选择可以做到这一点:使用Array#pack(所有版本的Ruby):expected=["d19b86"].pack

ruby - ruby 如何完成这项任务(Ruby 中不区分大小写的字符串搜索和替换)?

我在用Ruby替换字符串时遇到一些问题。我的原文:人之所为不如兽之所为。我想替换为:==What==humandoesisnotlike==what==animaldoes.我在使用gsub时遇到区分大小写的问题。(例如,什么,什么)我想保留原始文本。有什么解决办法吗? 最佳答案 如果我理解正确,这就是你想要做的:puts"Whatthehumandoesisnotlikewhatanimaldoes.".gsub(/(what)/i,'==\1==')输出==人类所做的==不同于==动物所做的。

ruby-on-rails - 使用 Ruby/Rails 进行 base 64 URL 解码?

我正在使用FacebookAPI和RubyonRails,我正在尝试解析返回的JSON。我遇到的问题是Facebookbase64URL对其数据进行编码。Ruby没有内置的base64URL解码。关于base64编码和base64URL编码的区别,seewikipedia.我如何使用Ruby/Rails对此进行解码?编辑:因为有些人阅读有困难——base64URL与base64不同 最佳答案 Dmitry的回答是正确的。它说明了在字符串解码之前必须出现的“=”符号填充。我一直收到格式错误的JSON,最后发现这是由于填充造成的。Rea

ruby - 如何在 Ruby 中使用 RegEx 更改字符串中字母的大小写

假设我有一个字符串:“hEY”我想把它转换成“嘿”string.gsub!(/([a-z])([A-Z]+)/,'\1'.upcase)这是我的想法,但是当我在gsub方法中使用它时,upcase方法似乎什么都不做。这是为什么?编辑:我想出了这个方法:string.gsub!(/([a-z])([A-Z]+)/){|str|str.downcase!.capitalize!}有没有办法在正则表达式中做到这一点?我不太明白'\1''\2'的意思。那是反向引用吗?这是如何工作的 最佳答案 @sawa有简单的答案,你已经用另一种机制编辑了

ruby-on-rails - 如何使用 Rails 和 Paperclip 在 Google Cloud Storage 上存储照片?

到目前为止,我一直在使用AmazonS3来存储用户的文件。这里需要做的是:为存储桶指定AmazonS3凭据添加'aws-sdk'gem到Gemfile在模型中:has_attached_file:avatar,:styles=>{:big=>"100x100#",:thumb=>"25x25#"},:storage=>:s3,:s3_credentials=>"#{Rails.root}/config/s3.yml",:path=>":rails_root/public/users/:id/:style/:basename.:extension",:url=>"/users/:id/:

ruby-on-rails - 标题化连字符的名称

Rails'titleize方法删除连字符,Ruby的capitalize方法不会将连字符后面的单词大写。我想要如下内容:"mary-joespencer-moore"=>"Mary-JoeSpencer-Moore""mary-louiseo'donnell"=>"Mary-LouiseO'Donnell" 最佳答案 CheckTitelizeimplementation从中你可以得到:"mary-joespencer-moore".humanize.gsub(/\b('?[a-z])/){$1.capitalize}会给你=>"

ruby-on-rails - 将 RSpec 与 Ruby on Rails 结合使用的国际字符

我刚刚开始使用RSpec,我在RSpecgithub存储库上复制了非常简单的测试,以确保一切按预期工作:require'spec_helper'describe'HomePage'doit"Welcomestheuser"dovisit'/products'page.shouldhave_content("Welcome")endend当我将字符串更改为“Olá”或“Caçamba”之类的字符串时,问题就开始了。任何带有特殊字符的字符串。当我这样做时,出现以下错误:invalidmultibytechar(US-ASCII)(SyntaxError)invalidmultibytech